package com.example.jianzhioffer;

import java.util.HashMap;

/**
 * Created by Quincy on 2018/9/23.
 * 数组中有一个数字出现的次数超过数组长度的一半，请找出这个数字。
 * 例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次，超过数组长度的一半，因此输出2。
 * 如果不存在则输出0。
 */
public class MoreThanHalfNum {
    public int MoreThanHalfNum_Solution(int [] array) {
        HashMap<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i < array.length; i++){
            if (!map.containsKey(array[i]))
                map.put(array[i],1);
            else {
                int count = map.get(array[i]);
                map.put(array[i], ++count);
            }
            int time = map.get(array[i]);
            if (time > array.length>>1)
                return array[i];
        }
        return 0;
    }
}
